// pages/postindex/postindex.js
import {getPostsList} from "../../api/post"
Page({

  /**
   * 页面的初始数据
   */
  data: {
    list:[],
    finish:false,
    leftHeight:0,
    rightHeight:0,
    leftList:[],
    rightList:[],
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.initData();
  },
  initData(){
    if (this.data.finish) {
      return
    }
    getPostsList(this.pageNum,15).then(res=>{
      console.log(res);
      // 执行这个的时候，list可能还没处理完
      this.data.list=this.data.list.concat(res.data.rows)
      if (this.pageNum*15>=res.data.total) {
        // 数据已经加载完了，不需要在加载数据了
        this.setData({
          finish:true
        })
      }
      this.handleList()
    })
  },
  handleList() {
    if (this.data.list.length === 0) {
      return;
    }
    // 把list均匀的分布在左右两侧
    // 小程序端提供了一个api可以获取图片的高度
    // shift unshift pop push
    const item = this.data.list.shift();
    // 记录高度的变化
    wx.getImageInfo({
      src: item.coverImgUrl,
      success: (res) => {
        //  判断一下这条数据应该放在左侧还是右侧
        if (this.data.leftHeight <= this.data.rightHeight) {
          // 放在左侧
          this.data.leftList.push(item)
          // 记录高度的变化
          this.data.leftHeight += res.height / res.width;
        } else {
          this.data.rightList.push(item)
          // 记录高度的变化
          this.data.rightHeight += res.height / res.width;
        }
        this.setData({
          leftList: this.data.leftList,
          rightList: this.data.rightList
        })
      },
      complete: () => {
        this.handleList()
      }
    })
  },
  // 页面上拉触底事件的处理函数

 onReachBottom: function () {
   this.pageNum++;
   this.initData();
 },

 skipSub(){
   wx.navigateTo({
     url: '/subPackageA/pages/home/index',
   })
 },
 skipChat(e){
   wx.navigateTo({
     url: '/pages/chat/chat?id='+e.currentTarget.dataset.id,
   })
 },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})